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WE CLAIM 



1. A direct memory access controller for controlling data transfer between a data 
source and a data destination comprising: 

a read/write port operable to receive data from said data source via a source bus 
and to output said received data to said data destination via a destination bus; wherein 

said direct memory access controller is operable in response to a predetermined 
number of clock pulses, to control said read/write port to output said received data said 
predetermined number of clock pulses after having received it. 

2. A direct memory access controller according to claim 1, wherein said 
predetermined number of clock pulses is one and said memory access controller 
comprises a register to store said received data during said one clock cycle prior to 
outputting said received data. 



3. A direct memory access controller according to claim 1, wherein said 
predetermined number of clock pulses is one and said memory access controller 
comprises two registers arranged in parallel to each other, each operable to store 
alternate items of said received data during a clock cycle prior to outputting said stored 

20 items. 

4. A direct memory access controller according to claim 1, wherein said 
predetermined number of clock pulses is zero, and said input port is connected to said 
output port, such that said received data is not stored within said direct memory access 

25 controller. 

5. A direct memory access controller according to claim 4, further 
comprising combinatorial logic between said input and said output port. 



6. A direct memory access controller according to claim 1, wherein said 
predetermined number of clock pulses is two and said memory access controller 
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comprises an input register and an output register to store said received data during 
said two clock cycles prior to outputting it. 

7. A direct memory access controller according to claim 1, wherein said 
5 source bus and said destination bus comprise a single bus, said single bus comprising 
separate read and write paths, said read/write port comprising a single port having a 
read channel operable to read data from said read path and a write channel operable to 
write data to said write path, such that data transfers from said data source to said read 
channel are received from said read path and data transfers to said data destination are 
10 output to said write path independently of said read path. 

8. A direct memory access controller according to claim 1, said read/write 
port further comprising a control channel operable to output control signals to a 
control path on said bus, said direct memory access controller further comprising: 
1 5 control logic, said control logic being operable to generate at least one of the 

following control signals: 

a source control signal specifying at least one data transfer from said data 
source, said control channel of said read/write port being operable to output said 
source control signal to said data source via said control path on said bus prior to 
20 receiving said received data; and 

a destination control signal specifying said at least one data transfer to said data 
destination, said control channel of said read/write port being operable to output said 
destination control signal to said data destination via said control path on said bus 
independently of whether said received data has been received at said read/write 
25 port. 

9. A direct memory access controller according to claim 8, wherein said at 
least one data transfer comprises a sequence of data transfers from a plurality of 
consecutive addresses, said control logic being operable to generate single read and 
30 write control signals to respectively control each read and write of said sequence of 
data transfers from said data source. 
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10. A direct memory access controller according to claim 9, wherein said 
single source control signal controls said sequence of data transfers from said 
plurality of consecutive addresses to be transferred from a central address first, said 
transfer wrapping round to send data from said initial address following sending data 

5 from said final address of said consecutive addresses. 

11. A direct memory access controller according to claim 10, said control 
logic being operable to generate a single destination control signal to control writing 
of said sequence of data transfers to said data destination. 

10 

12. A direct memory access controller according to claim 1, wherein said 
data source and said data destination each comprise one of either a memory and a 
peripheral. 

15 13. A direct memory access controller for controlling data transfer between 

a data source and a data destination comprising: 

a single read/write port comprising a read channel operable to receive data 

from said data source via a read path on a bus and a write channel operable to output 

said received data to said data destination via a write path on said bus, said read and 
20 write channel being operable to perform data reads and writes independently of each 

other. 

14. A direct memory access controller according to claim 13, said direct 
memory access controller further comprising control logic, said control logic being 
25 operable: 

to generate a source control signal specifying at least one data transfer from 
said data source, said read/write port further comprising a control channel, operable 
to output control signals along a control path of said bus, said control channel being 
operable to output said source control signal to said data source prior to receiving 
30 said received data at said read channel; and 

to generate a destination control signal specifying said at least one data transfer 
to said data destination, said control channel being operable to output said 
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destination control signal to said data destination independently of whether said 
received data has been received at said read channel. 

15. A direct memory access controller according to claim 13, wherein said 
5 at least one data transfer comprises a sequence of data transfers from a plurality of 
consecutive addresses, said control logic being operable to generate a single source 
control signal to control sending of said sequence of data transfers from said data 
source. 

10 16. A direct memory access controller according to claim 15, said control 

logic being operable to generate a single destination control signal to control writing 
of said sequence of data transfers to said data destination. 

17. A direct memory access control method for controlling data transfer 
1 5 between a data source and a data destination comprising the steps of: 

receiving data from said data source via a source bus at a read/write port; 
detecting a predetermined number of clock pulses; 

in response to said detected predetermined number of clock pulses, controlling 
said read/write port to output said received data to said data destination via a 
20 destination bus said predetermined number of clock pulses after having received it. 

18. A direct memory access control method according to claim 17, wherein 
said predetermined number of clock pulses is one and said method comprises the 
further step of storing said received data in a register during said one clock cycle prior 

25 to outputting it. 

19. A direct memory access control method according to claim 17, wherein 
said predetermined number of clock pulses is one and said received data comprises n 
data items, said method comprising the further steps of: 

30 (i) storing a first data item of said received data in one of two registers arranged 

in parallel during one clock cycle; 
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(ii) outputting said data item stored during said previous clock cycle fiom one 
of said two registers and storing a further data item in said other of said two registers 
during a subsequent clock cycle, wherein step (ii) is performed n -1 times, and 

(iii) outputting the last data item of stored data during a further subsequent 
clock cycle. 

20. A direct memory access control method according to claim 17, wherein 
said predetermined number of clock pulses is zero, and said read/write port is 
controlled to output said received data after having received it, without storing it. 
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21. A direct memory access control method according to claim 17, wherein 
said predetermined number of clock pulses is two and said method comprises the 
further step of storing said received data in an input register during one clock cycle and 
storing said received data in an output register during a subsequent clock cycle prior to 

15 outputting it. 

22. A direct memory access control method according to claim 17, wherein 
said source bus and said destination bus comprise a single bus, said single bus 
comprising separate read and write paths, said read/write port comprising a single port 

20 having a read channel operable to read data from said read path and a write channel 
operable to write data to said write path, said method controlling said read channel to 
receive data transfers from said data source via said read path, and controlling said 
write channel to output said received data to said data destination via said write path 
independently of said read path. 

25 

23. A direct memory access control method according to claim 17, said 
method comprising the further step of generating at least one of the following control 
signals: 

a source control signal specifying at least one data transfer from said data 
30 source and controlling a control channel of said read/write port to output said source 
control signal to said data source via a control path on said bus prior to receiving said 
received data; and 
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a destination control signal specifying said at least one data transfer to said data 
destination, and controlling a control channel of said read/write port to output said 
destination control signal to said data destination via said control path on said bus 
independently of whether said received data has been received at said read/write 
5 port. 

24. A direct memory access control method according to claim 23, wherein 
said at least one data transfer comprises a sequence of data transfers from a plurality 
of consecutive addresses, said method generating a single source control signal to 

1 0 control sending of said sequence of data transfers from said data source. 

25. A direct memory access control method according to claim 24, wherein 
said single source control signal controls said sequence of data transfers from said 
plurality of consecutive addresses to be transferred from a central address first, said 

15 transfer wrapping round to send data from said initial address following sending data 
from said final address of said consecutive addresses. 

26. A direct memory access control method according to claim 24, said 
method generating a single destination control signal to control writing of said 

20 sequence of data transfers to said data destination. 

27 A direct memory access control method according to claim 17, wherein 
said data source and said data destination each comprise one of either a memory and a 
peripheral. 

25 

28. A direct memory access control method for controlling data transfer 
between a data source and a data destination comprising the steps of: 

receiving at a read channel of a single read/write port data from said data 
source via a read path on a bus; and 
30 outputting said received data from a write channel of said single read/write port 

to said data destination via a write path on said bus; wherein 
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said read and write channel perform data reads and writes independently of 
each other. 

29. A direct memory access control method according to claim 28, said 
method further comprising the steps of: 

generating a source control signal specifying at least one data transfer from 
said data source and controlling a control channel of said read/write port to output 
said source control signal to said data source via a control path on said bus prior to 
receiving said received data; and 

generating a destination control signal specifying said at least one data transfer 
to said data destination, and controlling a control channel of said read/write port to 
output said destination control signal to said data destination via said control path on 
said bus independently of whether said received data has been received at said 
read/write port. 

30. A direct memory access control method according to claim 29, wherein 
said at least one data transfer comprises a sequence of data transfers from a plurality 
of consecutive addresses, said method generating a single source control signal to 
control sending of said sequence of data transfers from said data source. 

31. A direct memory access control method according to claim 30, said 
method generating a single destination control signal to control writing of said 
sequence of data transfers to said data destination. 



32. A computer program product, which is operable when run on a data 
processor to control the data processor to perform the steps of the method according to 
any one of claims 17 to 31. 



